package offer;

/**
 * 剑指 Offer 15. 二进制中1的个数
 */
public class Hamming {
    public int hammingWeight(int n) {
        // 常规方案 循环遍历, 右移至0
        int res = 0;
        while (n != 0) {
            res += n & 1;
            n >>>= 1; // 无符号右移
        }
        return res;
    }

    public int hammingWeight_2(int n) {
        int res = 0;
        while (n != 0) {
            n &= n - 1; // 去掉最右边的1
            res++;
        }
        return res;
    }
}
